Challenge programming

JavaScript

クイズゲームのアプリケーション作成について➃

プレイ画面の作成

クイズ問題前のプレイが始まる表示を作成してみましょう。クリックするとテキストが表示されるようにします。

赤字が追記、修正した箇所です。

quiz.js
class quiz {
constructor(rootElm){
this.rootElm = rootElm;
}
rootElmにアプリケーション全体の親要素が反映される想定してます。this.rootElmではクラスの各メソッドからrootElmを参照できるようにプロパティに代入してます。
async init(){
await this.fetchQuizData();
this.displayStartView();
}
fetchQuizDataというメソッド、displayStartViewメソッドを呼び出しています。
async fetchQuizData(){
try{
const response = await fetch('quiz.json');
this.quizData = await response.json();
}
catch(e){
this.rootElm.innerText = 'クイズ問題の読み込みに失敗';
console.log(e)
}
} // fetchQuizData
エラー処理を入れるためtry,catchで例外処理を入れています。通信ができない場合などエラーが発生した時には、this.rootElm.innerTextでブラウザ上にエラー表示を行い、デバックのために console.log(e)でエラー情報を出力させます。
displayStartView(){
const levelStrs = Object.keys(this.quizData);
const optionStrs = [];
for (let i =0; levelStrs.length >i; i++){
optionStrs.push(`<option value="${levelStrs[i]}" name="level">難易度${i + 1 }</option>`);
}
const html =`
<select class="levelSelector">
${optionStrs.join('')}
</select>
<button class="startBtn">START</button>
`;
const parentElm = document.createElement('div');
parentElm.innerHTML = html

const startBtnElm = parentElm.querySelector('.startBtn');
startBtnElm.addEventListener('click', () =>{
this.displayQuestionView();
});
this.rootElm.appendChild(parentElm)
} //displayStartView
displayStartViewメソッドは、呼び出すと開始画面を表示するもの。
ここではquizDataから必要な情報を取得し、セレクトボックスとなるHTMLを構築した後、画面に表示しています。

セレクトボックスのバリューに設定する情報を作成します。
実装としてはObject.keyメソッドにより、quizDataのキーを配列として取り出しています。
次にlevelStrsの値からoptionタグの情報を作成しています。
optionタグの情報を配列で作成してからjoinで処理します。
displayQuestionView(){
const html = `
<p>ゲームを開始します</p>
`;
const parentElm = document.createElement('div');
parentElm.className ='question';
parentElm.innerHTML = html;

this.rootElm.innerHTML = '';
this.rootElm.appendChild(parentElm);
}
//displayQuestionView
} // class quiz
STARTボタンをクリックした時の処理についてです。プレイ画面となるHTMLを作成し、rootElmの中身をinnerHTMLで空にした上で反映しています。
new quiz(document.getElementById('app')).init();newでの呼び出し時に要素情報(rootElm)を引数として渡しています。

それでは改めて、「ブラウザ以外でのJavaScriptの実行」をしていきましょう。

ターミナルから「http-server」コマンドを実行

そうすると以下のようにサーバーアプリケーションの情報がターミナルに表示されます。

この表示されているどちらかの情報のURLをブラウザのアドレスバーにコピペしてみましょう。そしてQuizフォルダからquizGame.htmlファイルを選択します。

STARTボタンをクリックするとテキストが表示されます。

お疲れ様でした。今回はここまでにしましょう。ゆっくりマイペースで継続しましょう。

この本から引用、参考にして学び、完成させることができました。しかし、ここではプログラミング初心者の私が詳しく解説することは、おこがましく、難しく出来ません(ToT)
その点、この本では丁寧な解説が載っていますので、解説とともにコードを書き、完成させればより深く学ぶことができます(^.^)、実際、初心者の私でもわかりやすかったです。身に付け消えないスキルが3,000円弱ならコスパよく、買っておいてよかったと満足してます。


わからないことはプロフェッショナルから学ぶのが一番 | The best way to learn what you don't know is from professionals.

キャリアアップに必要なスキルを取得しよう。| Get the skills you need to advance your career.

オンラインで受講ができるスクールですので、全国どこからでも。 | Since it is a school where you can take classes online, you can take it from anywhere in the country.

ぺージの先頭に戻る(Return to top of page)


©2020年9月 Challenge programming

プライバシーポリシー

  • 千葉県から無農薬の野菜を産地直送
  • 野菜もとれるバランスの良い食事をお届け
  • 目覚まし時計は"音"から"光"の時代へ!最先端の目覚まし時計とは